package com.learn.acm.bytedance;

import com.learn.acm.po.TreeNode;

/**
 *
 * 110. 平衡二叉树
 * 给定一个二叉树，判断它是否是高度平衡的二叉树。
 *
 * 本题中，一棵高度平衡二叉树定义为：
 *
 * 一个二叉树每个节点 的左右两个子树的高度差的绝对值不超过1。
 *
 * 示例 1:
 *
 * 给定二叉树 [3,9,20,null,null,15,7]
 *
 *     3
 *    / \
 *   9  20
 *     /  \
 *    15   7
 * 返回 true 。
 *
 * 示例 2:
 *
 * 给定二叉树 [1,2,2,3,3,null,null,4,4]
 *
 *        1
 *       / \
 *      2   2
 *     / \
 *    3   3
 *   / \
 *  4   4
 * 返回 false 。
 * @author zhongshitao
 * @date 2020/9/22 6:03 下午
 */
public class Solution110 {

    int low = Integer.MAX_VALUE, high = Integer.MIN_VALUE;
    public boolean isBalanced(TreeNode root) {

        return recure(root) != -1;
    }

    private int recure(TreeNode node) {
        if (null == node) {
            return 0;
        }
        int left = recure(node.left);
        if (left < 0) return -1;
        int right = recure(node.right);
        if (right < 0) return -1;
        return Math.abs(left - right) < 2 ? Math.max(left, right) + 1 : -1;
    }
}
